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Foreword 



rd , 



This Technical Specification has been produced by the 3 Generation Partnership Project (3GPP). 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 

where: 

X the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 



Introduction 



rd , 



The present document is part of a TS-family covering the 3 Generation Partnership Project: Technical Specification 
Group Services and System Aspects; Telecommunication management; as identified below: 

32.601: "Configuration Management (CM); Basic CM Integration Reference Point (IRP); Requirements". 

32.602: "Configuration Management (CM); Basic CM Integration Reference Point (IRP): Information 

Service (SS)". 

32.603: "Configuration Management (CM); Basic CM Integration Reference Point (IRP): Common 

Object Request Broker Architecture (CORBA) Solution Set (SS)". 

32.604: "Configuration Management (CM); Basic CM Integration Reference Point (IRP) Common 

Management Information Protocol (CMIP) Solution Set (SS)". 

Configuration Management (CM), in general, provides the operator with the ability to assure correct and effective 
operation of the 3G network as it evolves. CM actions have the objective to control and monitor the actual configuration 
on the Network Elements (NEs) and Network Resources (NRs), and they may be initiated by the operator or by 
functions in the Operations Systems (OSs) or NEs. 

CM actions may be requested as part of an implementation programme (e.g. additions and deletions), as part of an 
optimisation programme (e.g. modifications), and to maintain the overall Quality of Service (QoS). The CM actions are 
initiated either as single actions on single NEs of the 3G network, or as part of a complex procedure involving actions 
on many resources/objects in one or several NEs. 
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Scope 



The purpose of this Basic Configuration Management (CM) IRP: CORBA Solution Set is to define the mapping of the 
Basic CM IRP: IS (see 3GPP TS 32.602 [4]) to the protocol specific details necessary for implementation of this IRP in 
a CORBA/IDL environment. 

This document defines NRM independent data types and methods. 

This Solution Set specification is related to 3G TS 32.602 V6.1.X. 



References 



The following documents contain provisions which, through reference in this text, constitute provisions of the present 
document. 

• References are either specific (identified by date of publication, edition number, version number, etc.) or 
non-specific. 

• For a specific reference, subsequent revisions do not apply. 

• For a non-specific reference, the latest version applies. In the case of a reference to a 3GPP document (including 
a GSM document), a non-specific reference implicitly refers to the latest version of that document in the same 
Release as the present document. 

[I] 3GPP TS 32.101: "Telecommunication management; Principles and high level requirements". 

[2] 3GPP TS 32.102: "Telecommunication management; Architecture". 

[3] 3GPP TS 32.600: "Telecommunication management; Configuration Management (CM); Concept 

and high-level requirements". 

[4] 3GPP TS 32.602: "Telecommunication management; Configuration Management (CM); Basic CM 

Integration Reference Point (IRP) Information Service (IS)". 

[5] 3GPP TS 32.300: "Telecommunication management; Configuration Management (CM); Name 

convention for Managed Objects". 

[6] OMG Notification Service, Version 1 .0. 

[7] OMG CORBA services: Common Object Services Specification, Update: November 22, 1996. 

[8] The Common Object Request Broker: Architecture and Specification (for specification of valid 

version, see [1]). 

[9] 3GPP TS 32.303: "Telecommunication management; Configuration Management (CM); 

Notification Integration Reference Point (IRP): Common Object Request Broker Architecture 
(CORBA) Solution Set (SS)". 

[10] 3GPP TS 32.312: "Telecommunication management; Generic Integration Reference Point (IRP) 

management; Information Service (IS)". 

[II] 3GPP TS 32.663: "Telecommunication management; Configuration Management (CM); Kernel 
CM Integration Reference Point (IRP): Common Object Request Broker Architecture (CORBA) 
Solution Set (SS)". 
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Definitions and abbreviations 



3.1 Definitions 

For terms and definitions please refer to 3GPP TS 32.101 [1], 3GPP TS 32.102 [2], 3GPP TS 32.600 [3] and 
3GPPTS 32.602 [4]. 

3.2 Abbreviations 

For the purposes of the present document, the following abbreviations apply: 

CORBA Common Object Request Broker Architecture 

DN Distinguished Name 

IS Information Service 

IDL Interface Definition Language (OMG) 

IRP Integration Reference Point 

MO Managed Object 

MOC Managed Object Class 

NRM Network Resource Model 

OMG Object Management Group 

SS Solution Set 



4 IRP document version number string 

The IRP document version number (sometimes called "IRPVersion" or "SS version number") string is used to identify 
this specification. The string is derived using a rule described in 3GPP TS 32.312: [10]. 

This string (or sequence of strings, if more than one version is supported) is returned in getBasicCmlRPVersion 
method. 



Architectural features 



The overall architectural feature of Basic Configuration Management IRP is specified in 3GPP TS 32.602 [4]. 
This clause specifies features that are specific to the CORBA SS. 

5.1 Filter language 

The filter language used in the SS is the Extended Trader Constraint Language (see OMG Notification Service [6]). 
IRP Agents may throw a FilterComplexityLimit exception when a given filter is too complex. However, for 3GPP 
Release 99 an "empty filter" shall be used i.e. a filter that satisfies all MOs of a scoped search (this does not affect the 
filter for notifications as defined in the Notification IRP - see 3GPP TS 32.303 [9]). 

5.2 Syntax for Distinguished Names and Versions 

The format of a Distinguished Name is defined in 3GPP TS 32.300 [5]. 
The version of this IRP is represented as a string (see also clause 4). 



£75/ 



3GPP TS 32.603 version 6.3.1 Release 6 



ETSI TS 132 603 V6.3.1 (2005-04) 



6 Mapping 

6.1 General mappings 

The IS parameter name managedObjectlnstance is mapped into DN. 

Attributes modelling associations as defined in the NRM (here also called "reference attributes") are in this SS mapped 
to attributes. The names of the reference attributes in the NRM are mapped to the corresponding attribute names in the 
MOC. When the cardinality for an association is 0..1 or 1..1 the datatype for the reference attribute is defined as an 
MOReference. The value of an MO reference contains the distinguished name of the associated MO. When the 
cardinality for an association allows more than one referred MO, the reference attribute will be of type 
MOReferenceSet, which contains a sequence of MO references. 

If a reference attribute is changed, an Attribute ValueChange notification (see TS 32.663 [11]) is emitted. 



6.2 Operation mapping 



The Basic CM IRP: IS (see 3GPP TS 32.602 [4]) defines semantics of operation visible across the Basic Configuration 
Management IRP. Table 1 indicates mapping of these operations to their equivalents defined in this SS. 

Table 1 : Mapping from IS Operation to SS equivalents 



IS Operation 
(3GPP TS 32.602 [4]) 


SS Method 


Qualifier 


getMoAttributes 


BasicCmlrpOperations::find_managed_objects 
BasicCmlnformationlterator::next basicCmlnformations 


M 


getContainment 


BasicCmlrpOperations::find_managed_objects 
BasicCmlnformationlterator::next basicCmlnformations 





getlRPVersion (see note) 


get basicCm IRP version 


M 


cancelOperation 


BasicCmlnformationlterator::destroy 





createMo 


BasicCmlrpOperations:;create managed object 





deleteMo 


BasicCmlrpOperations::delete managed objects 





setMoAttributes 


BasicCmlrpOperations::modify managed objects 





getOperationProfile (see note) 


get basicCm IRP operation profile 





getNotificationProfile (see note) 


get basicCm IRP notification profile 





NOTE: This operation is of IOC ManagedGenericIRP specified in [10]. The IOC BasicCmIRP of [4] inherits from it. 



6.3 Operation parameter mapping 



The Basic CM IRP: IS (see 3GPP TS 32.602 [4]) defines semantics of parameters carried in operations across the Basic 
Configuration Management IRP. Tables 2 through 8 indicate the mapping of these parameters, as per operation, to their 
equivalents defined in this SS. 

The SS operation find_managed_objects is equivalent to the IS operation getMoAttributes when called with 
ResultContents set to NAMES_AND_ATTRIBUTES. Iterating the BasicCmlnformationlterator is used to fetch the 
result. 
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Table 2: Mapping from IS getMoAttributes parameters to SS equivalents 



IS Operation parameter 


SS IVIethod parameter 


Qualifier 


invokeldentifier 


- (No equivalence) 


- 


invokeldentifierOut 


Return value of type BasicCmlnformationlterator 


M 


baseObjectlnstance 


in DN baseObject 


M 


scope 


in SearchControl searchControl (SearchControl.type and SearchControl. level) 


M 


filter 


in SearchControl searchControl (SearchControl.filter) 


M 


attributeListIn 


in AttributeNameSet requestedAttributes 


M 


managedObjectClass 

managedObjectlnstance 

attributeListOut 


Return value of type BasicCmlnformationlterator - parameter out ResultSet 
fetchedElements of method next_basicCm Informations 


M 


status 


Exceptions: 

FindlVlanagedObjects, 

ManagedGenericlRPSystem::lnvalidParameter, 

UndefinedlVIOException, 

lllegalDNFormatException, 

UndefinedScopeException, 

lllegalScopeTypeException, 

lllegalScopeLevelException, 

lllegalFilterFormatException, 

FilterComplexityLimit 


M 



The SS operation find_managed_objects is equivalent to the IS operation getContainment when called with 
ResultContents set to NAMES. Iterating the BasicCmlnformationlterator is used to fetch the result. 

Table 3: Mapping from IS getContainment parameters to SS equivalents 



IS Operation parameter 


SS Method parameter 


Qualifier 


invokeldentifier 


- (No equivalence) 


- 


invokeldentifierOut 


Return value of type BasicCmlnformationlterator 


M 


baseObjectlnstance 


in DN baseObject 


M 


scope 


in SearchControl searchControl (SearchControl.type and SearchControl. level) 





Not specified in IS 


in SearchControl searchControl (SearchControl.filter) 


M 


containment 


Return value of type BasicCmlnformationlterator - parameter out ResultSet 
fetchedElements of method next basicCm Informations 


M 


status 


Exceptions: 

FindManagedObjects, 

ManagedGenericlRPSystem::OperationNotSupported, 

IVIanagedGenericlRPSystem::ParameterNotSupported, 

ManagedGenericlRPSystem::lnvalidParameter, 

IVIanagedGenericlRPSystem::ValueNotSupported, 

UndefinedlVIOException, 

lllegalDNFormatException, 

UndefinedScopeException, 

lllegalScopeTypeException, 

lllegalScopeLevelException, 

lllegalFilterFormatException, 

FilterComplexityLimit 


M 



Table 4: Mapping from IS getlRPVersion parameters to SS equivalents 



IS Operation parameter 


SS Method parameter 


Qualifier 


versionNumberSet 


Return value of type ManagedGenericlRPConstDefs::VersionNumberSet 


M 


status 


Exceptions: 
GetBasicCmlRPVersion 


M 
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Table 5: Mapping from IS cancelOperation parameters to SS equivalents 



IS Operation parameter 


SS IVIethod parameter 


Qualifier 


invokeldentifier 


- (Not applicable, the BasicCmlnformationlterator instance identifies the ongoing 
operation) 


M 


status 


Exceptions: 

ManagedGenericlRPSystem::OperationNotSupported, 

DestroyException 


M 



Table 6: Mapping from IS createMo parameters to SS equivalents 



IS Operation parameter 


SS Method parameter 


Qualifier 


managedObjectClass 
managedObjectlnstance 


in DN objectName 


M 


referenceObjectlnstance 


in DN referenceObject 





attributeListIn 
attributeListOut 


inout IVIoAttributeSet attributes 


M 


status 


out AttributeErrorSeq attributeErrors 

Exceptions: 

CreateManagedObject, 

IVIanagedGenericlRPSystem::OperationNotSupported, 

ManagedGenericlRPSystem::ParameterNotSupported, 

IVIanagedGenericlRPSystem::lnvalidParameter, 

Undefined IVIOException, 

lllegalDNFormatException, 

DuplicatelVIO, 

CreateNotAllowed, 

ObjectClasslVlismatch, 

NoSuchObjectClass, 

ParentObjectDoesNotExist 


M 



Table 7: Mapping from IS deleteMo parameters to SS equivalents 



IS Operation parameter 


SS IVIethod parameter 


Qualifier 


baseObjectlnstance 


in DN baseObject 


M 


scope 


in SearchControl searchControl (SearchControl.type and SearchControl. level) 


M 


filter 


in SearchControl searchControl (SearchControl.filter) 


M 


deletionLlst 


Return value of type DeleteResultlterator - parameter out ResultSet 
fetchedElements of method next basicCm Informations 


M 


status 


Return value of type DeleteResultlterator - parameter out DeleteErrorSeq 

fetchedDeleteErrors of method next_deleteErrors 

Exceptions: 

DeletelVlanagedObjects, 

ManagedGenericlRPSystem::OperationNotSupported, 

IVIanagedGenericlRPSystem::lnvalidParameter, 

Undefined IVIoException, 

lllegalDNFormatException, 

UndefinedScopeException, 

lllegalScopeTypeException, 

lllegalScopeLevelException, 

lllegalFilterFormatException, 

FilterComplexityLimit 


M 
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Table 8: Mapping from IS setMoAttributes parameters to SS equivalents 



IS Operation parameter 


SS IVIethod parameter 


Qualifier 


baseObjectlnstance 


in DN baseObject 


M 


scope 


in SearchControl searchControl (SearchControl.type and SearcliControl. level) 


M 


filter 


in SearchControl searchControl (SearchControl.filter) 


M 


modification List 


in AttributelVlodificationSet modifications 


M 


modification ListOut 


Return value of type ModifyResultlterator - parameter out ResultSet 
fetchedElements of method next basicCm Informations 


M 


status 


Return value of type ModifyResultlterator - parameter out 

ModifyAttributeErrorsSeq fetchedlVlodifyErrors of method next_modifyErrors 

Exceptions: 

IVIodifylVlanagedObjects, 

ManagedGenericlRPSystem::OperationNotSupported, 

IVIanagedGenericlRPSystem::lnvalidParameter, 

UndefinedMoException, 

lllegalDNFormatException, 

UndefinedScopeException, 

lllegalScopeTypeException, 

lllegalScopeLevelException, 

lllegalFilterFormatException, 

FilterComplexityLimit 


M 



Table 9: Mapping from IS getOperationProfile parameters to SS equivalents 



IS Operation parameter 


SS Method parameter 


Qualifier 


irpVersion 


ManagedGenericlRPConstDefs::VersionNumber basicCm IRP version 


M 


operationNameProfile, 
operationParameterProfile 


Return value of type ManagedGenericlRPConstDefs::l\/lethodList 


M 


status 


Exceptions: 

GetBasicCmlRPOperationProfile, 

l\/lanagedGenericlRPSystem::OperationNotSupported, 

ManagedGenericlRPSystem::lnvalidParameter 


M 



Table 10: Mapping from IS getNotificationProfile parameters to SS equivalents 



IS Operation parameter 


SS Method parameter 


Qualifier 


irpVersion 


ManagedGenericlRPConstDefs::VersionNumber basicCm IRP version 


M 


notificationNameProfile, 
notificationParameterProfile 


Return value of type ManagedGenericlRPConstDefs::MethodList 


M 


status 


Exceptions: 

GetBasicCmlRPNotificationProfile, 

ManagedGenericlRPSystem::OperationNotSupported, 

IVIanagedGenericlRPSystem::lnvalidParameter 


M 



Void 
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Annex A (normative): 
CORBA IDL, Access Protocol 

A.1 IDL specification (file name 
"BasicCMIRPConstDefs.idI") 

// File: BasicCMIRPConstDefs.idI 

#ifndef _BASICCMIRPCONSTDEFS_IDL_ 
#define _BASICCMIRPCONSTDEFS_IDL_ 

// This statement must appear after all include statements 
#pragma prefix "3gppsa5.org" 

/* ## Module: BasicCMIRPConstDef s 

This module contains commonly used definitions for BasicCMIRP, 

V 

module BasicCMIRPConstDef s 



* Defines the name of a Managed Object Class 
V 

typedef string MOClass; 

/*■*■ 

* The format of Distinguished Name (DN) is specified in 3GPP TS 32.300 

* "Name Conventions for Managed Objects". 
V 

typedef string DN; 



* Defines the name of an attribute of a Managed Object 
V 

typedef string MOAttributeName; 

* Defines the value of an attribute of a Managed Object in form of a CORBA 

* Any. Apart from basic datatypes already defined in CORBA, the allowed 

* attribute value types are defined in the AttributeTypes module. 
V 

typedef any MOAttributeValue; 

* 

* In this version the only allowed filter value is "TRUE" i.e. a filter that 

* matches everything. 
V 

typedef string FilterType; 

* ResultContents is used to tell how much information to get back 

* from the f ind_managed_ob jects operation. 

* NAMES: Used to get only Distinguished Name 
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* for MOs . 

* The name contains both the MO class 

* and the names of all superior objects in the naming 

* tree. 

* NAMES_AND_ATTRIBUTES: Used to get both NAMES plus 

* MO attributes (all or selected) . 
V 

enum ResultContents 
{ 

NAMES, 

NAMES_AND_ATTRIBUTES 



* ScopeType defines the kind of scope to use in a search 

* together with SearchControl . level, in a SearchControl value. 
* 

* SearchControl . level is always >= . If a level is bigger than the 

* depth of the tree there will be no exceptions thrown. 

* BASE_ONLY: level ignored, just return the base object. 

* BASE_NTH_LEVEL : return all subordinate objects that are on "level" 

* distance from the base object, where is the base object. 

* BASE_SUBTREE : return the base object and all of its subordinates 

* down to and including the nth level. 

* BASE_ALL: level ignored, return the base object and all of it's 

* subordinates. 
V 

enum ScopeType 
{ 

BASE_ONLY, 

BASE_NTH_LEVEL, 

BASE_SUBTREE, 

BASE_ALL 



* SearchControl controls the f ind_managed_ob ject search, 

* and contains : 

* the type of scope ("type" field), 

* the level of scope ("level" field), level means the "baseOb ject ", 

* level 1 means baseobject including its sub-ordinates etc.. 

* the filter ("filter" field), 

* the result type ("contents" field) . 

* The type, level and contents fields are all mandatory. 

* The filter field contains the filter expression. 

* The string "TRUE" indicates "no filter", 

* i.e. a filter that matches everything. 
V 

struct SearchControl 
{ 

ScopeType type; 

unsigned long level; 

FilterType filter; 

ResultContents contents; 



* Represents an attribute: "name" is the attribute name 

* and "value" is the attribute value. 
V 

struct MOAttribute 
{ 
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MOAttributeName name; 
MOAttributeValue value; 
}; 

typedef sequence <MOAttribute> MOAttributeSet ; 

struct Result 
{ 

DN mo; 

MOAttributeSet attributes; 

}; 

typedef sequence <Result> ResultSet; 

/** 

* AttributeErrorCategory defines the categories of errors, related to 

* attributes, that can occur during creation or modification of MOs . 
* 

* NO_SUCH_ATTRIBUTE: The specified attribute does not exist. 

* INVALID_ATTRIBUTE_VALUE: The specified attribute value is not valid. 

* MISSING_ATTRIBUTE_VALUE: An attribute value is required but none was 

* provided and no default value is defined for the attribute. 

* INVALID_MODIFY_OPERATOR: The specified modify operator is not valid 

* (e.g. operator ADD_VALUES applied to a non multi-valued attribute 

* or operator SET_TO_DEFAULT applied where no default value is defined) . 

* MODIFY_NOT_ALLOWED: The modification of the attribute is not allowed. 

* MODIFY_FAILED : The modification failed because of an unspecified reason. 
V 

enum AttributeErrorCategory 
{ 

NO_SUCH_ATTRIBUTE, 

INVALID_ATTRIBUTE_VALUE, 

MIS S ING_ATTRIBUTE_VALUE , 

INVALID_MODIFY_OPERATOR, 

MODIFY_NOT_ALLOWED, 

MODIFY_FAILED 



* DeleteErrorCategory defines the categories of errors that can occur 

* during deletion of MOs. 

* SUBORDINATE_OBJECT: The MO cannot be deleted due to subordinate MOs. 

* DELETE_NOT_ALLOWED: The deletion of the MO is not allowed. 

* DELETE_FAILED : The deletion failed because of an unspecified reason. 
V 

enum DeleteErrorCategory 
{ 

SUBORDINATE_OBJECT, 

DELETE_NOT_ALLOWED, 

DELETE_FAILED 

}; 

/** 

* AttributeError represents an error, related to an attribute, that occured 

* during creation or modification of MOs. 

* It contains : 

* - the name of the indicted attribute ("name" field), 

* - the category of the error ("error" field), 

* - optionally, the indicted attribute value ("value" field), 

* - optionally, additional details on the error ("reason" field) . 
V 
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struct AttributeError 
{ 

MOAttributeName name; 

AttributeErrorCategory error; 

MOAttributeValue value; 

string reason; 

}; 

typedef sequence <AttributeError> AttributeErrorSeq; 

/** 

* DeleteError represents an error that occured during deletion of MOs . 

* It contains : 

* - the distinguished name of the indicted MO ( "ob jectName" field), 

* - the category of the error ("error" field), 

* - optionally, additional details on the error ("reason" field) . 
V 

struct DeleteError 
{ 

DN objectName; 

DeleteErrorCategory error; 

string reason; 

}; 

typedef sequence <DeleteError> DeleteErrorSeq; 

/** 

* Modif yAttributeErrors represents errors that occured during 

* modification of attributes of a MO. 

* It contains : 

* - the distinguished name of the indicted MO ("objectName" field), 

* - a sequence containing the attribute errors ("errors" field) . 
*/ 

struct Modif yAttributeErrors 
{ 

DN objectName; 

AttributeErrorSeq errors; 

}; 

typedef sequence <ModifyAttributeErrors> Modif yAttributeErrorsSeq; 
typedef sequence <MOAttributeName> AttributeNameSet ; 

* Modif yOperator defines the way in which an attribute value is to be 

* applied to an attribute in a modification of MO attributes. 
* 

* REPLACE: replace the current value with the provided value 

* ADD_VALUES: for a multi-valued attribute, add the provided values to the 

* current list of values 

* REMOVE_VALUES : for a multi-valued attribute, remove the provided values 

* from the current list of values 

* SET_TO_DEFAULT: set the attribute to its default value 
V 

enum Modif yOperator 
{ 

REPLACE, 

ADD_VALUES, 

REMOVE_VALUES, 

SET_TO_DEFAULT 

}; 
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* AttributeModif ication defines an attribute value and the way it is to 

* be applied to an attribute in a modification of MO attributes. 

* It contains : 

* - the name of the attribute to modify ("name" field), 

* - the value to apply to this attribute ("value" field), 

* - the way the attribute value is to be applied to the attribute 

* ("operator" field). 
V 

struct AttributeModif ication 
{ 

MOAttributeName name; 

MOAttributeValue value; 

Modif yOperator operator; 

}; 

typedef sequence <AttributeModif ication> AttributeModif icationSet; 

}; 

#endif // _BASICCMIRPCONSTDEFS_IDL_ 



A.2 IDL specification (file name "BasicCIVIIRPSystem.idI") 

// File: BasicCMIRPSystem. idl 

#ifndef _BASICCMIRPSYSTEM_IDL_ 
#define _BASICCMIRPSYSTEM_IDL_ 

#include "ManagedGenericIRPConstDef s . idl" 
#include "ManagedGenericIRPSystem. idl" 
♦include "BasicCMIRPConstDef s . idl" 

// This statement must appear after all include statements 
#pragma prefix "3gppsa5.org" 

module BasicCmlRPSystem 
{ 

exception IllegalFilterFormatException { 
string reason; 

}; 

exception IllegalDNFormatException { 
string reason; 

}; 

exception IllegalScopeTypeException { 
string reason; 

}; 

exception IllegalScopeLevelException { 
string reason; 

}; 

exception Undef inedMOException { 
string reason; 

}; 

exception Undef inedScopeException { 
string reason; 

}; 

exception FilterComplexityLimit { 
string reason; 
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exception DuplicateMO {}; 

exception CreateNotAllowed {}; 

exception Ob jectClassMismatch {}; 

exception NoSuchOb jectClass { 

BasicCMIRPConstDefs : :MOClass ob jectClass; 
}; 

exception ParentOb jectDoesNotExist {}; 

* System otherwise fails to complete the operation. System can provide 

* reason to qualify the exception. The semantics carried in reason 

* is outside the scope of this IRP . 
V 

exception NextBasicCmInf ormations { string reason; }; 

exception NextDeleteErrors { string reason; 

exception NextModifyErrors { string reason; 

exception DestroyException { string reason; 

exception GetBasicCmlRPVersion { string reason; }; 

exception GetBasicCmlRPOperationProf lie { string reason; }; 

exception GetBasicCmlRPNotif icationProf lie { string reason; }; 

exception FindManagedOb jects { string reason; }; 

exception CreateManagedOb ject { string reason; }; 

exception DeleteManagedOb jects { string reason; }; 

exception ModifyManagedOb jects { string reason; }; 

The BasicCmInf ormationlterator is used to iterate through a snapshot of 
Managed Object Information when IRPManager invokes find_managed_ob jects . 
IRPManager uses it to pace the return of Managed Object Information. 

IRP Agent controls the life-cycle of the iterator. However, a destroy 
operation is provided to handle the case where IRPManager wants to stop 
the iteration procedure before reaching the last iteration. 
V 
interface BasicCmInf ormationlterator 
{ 

/*■* 
This method returns between 1 and "how_many" Managed Object information. 
The IRPAgent may return less than "how_many" items even if there are 
more items to return. "how_many" must be non-zero. Return TRUE if there 
may be more Managed Object information to return. Return FALSE if there 
are no more Managed Object information to be returned. 

If FALSE is returned, the IRPAgent will automatically destroy the 
iterator . 

@parm how_many how many elements to return in the "f etchedElements " out 

parameter . 
@parm f etchedElements the elements. 
Sreturns A boolean indicating if any elements are returned. 

"f etchedElements " is empty when the BasicCmInf ormationlterator is 

empty . 
V 

boolean next_basicCmInf ormations ( 
in unsigned short how_many, 
out BasicCMIRPConstDef s : :ResultSet f etchedElements 
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) 

raises ( 

Next BasicCmIn format ions, 

ManagedGenericIRPSystem: : InvalidParameter, 
ManagedGenericIRPSystem: : OperationNotSupported) ; 

This method destroys the iterator. 
*/ 

void destroy () 
raises ( 

Destroy Except ion, 

ManagedGenericIRPSystem: : OperationNotSupported) ; 

}; // end of BasicCmInf ormationlterator 

The DeleteResult Iterator is used to iterate through the list of deleted MOs 
when IRPManager invokes method "delete_managed_ob jects" . 
IRPManager uses it to pace the return of Managed Object Information. 

IRP Agent controls the life-cycle of the iterator. However, a destroy 
operation is provided to handle the case where IRPManager wants to stop 
the iteration procedure before reaching the last iteration. 

V 
interface DeleteResultlterator : BasicCmInf ormationlterator 



I -k-k 

Inherited method "next_basicCmInf ormations " has the same behaviour as 
for interface BasicCmInf ormationlterator, except that: 

- The Managed Object information returned in parameter 

" f etchedElements " contains only the DNs of the deleted MOs 
(no attributes are returned) . 

- If FALSE is returned, the IRPAgent will not automatically destroy the 
iterator . 

V 

/** 

This method returns between and "how_many" deletion errors. The 

IRPAgent may return less than "how_many" items even if there are more 

items to return. "how_many" must be non-zero. Return TRUE if there are 

more deletion errors to return. Return FALSE if there are no more 
deletion errors to be returned. 

If FALSE is returned and last call to inherited method 
"next_basicCmInf ormations " also returned FALSE (i.e. no more Managed 
Object information to be returned) , the IRPAgent will automatically 
destroy the iterator. 

@parm how_many: how many deletion errors to return in the 

"f etchedDeleteErrors " out parameter. 
Sparm f etchedDeleteErrors : the deletion errors. 
Sreturns: a boolean indicating if any deletion errors are returned. 

boolean next_deleteErrors ( 

in unsigned short how_many, 

out BasicCMIRPConstDef s : : DeleteErrorSeq f etchedDeleteErrors 
) 
raises ( 
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NextDeleteErrors, 

ManagedGenericIRPSystem: : InvalidParameter ) ; 

}; // end of DeleteResult Iterator 

The ModifyResult Iterator is used to iterate through the list of modified 
MOs when IRPManager invokes method "modif y_managed_ob jects " . 
IRPManager uses it to pace the return of Managed Object Information. 

IRP Agent controls the life-cycle of the iterator. However, a destroy 
operation is provided to handle the case where IRPManager wants to stop 
the iteration procedure before reaching the last iteration. 
V 
interface ModifyResultlterator : BasicCmInf ormationlterator 
{ 

/** 

Inherited method "next_basicCmInf ormations " has the same behaviour as 
for interface BasicCmInf ormationlterator, except that: 

- The Managed Object information returned in parameter 

"f etchedElements " contains DNs and attributes of the modified MOs. 

- If FALSE is returned, the IRPAgent will not automatically destroy the 
iterator . 

*/ 

This method returns between and "how_many" modification errors. The 
IRPAgent may return less than "how_many" items even if there are more 
items to return. "how_many" must be non-zero. Return TRUE if there are 
more modification errors to return. Return FALSE if there are no more 
modification errors to be returned. 

If FALSE is returned and last call to inherited method 
"next_basicCmInf ormations " also returned FALSE (i.e. no more Managed 
Object information to be returned) , the IRPAgent will automatically 
destroy the iterator. 

@parm how_many: how many modification errors to return in the 

"f etchedModif yErrors " out parameter. 
@parm f etchedModif yErrors : the modification errors. 

Sreturns: a boolean indicating if any modification errors are returned. 
*/ 

boolean next_modif icationErrors ( 

in unsigned short how_many, 

out BasicCMIRPConstDef s : :Modif yAttributeErrorsSeq 
f etchedModif yErrors 
) 
raises ( 

NextModif yErrors, 

ManagedGenericIRPSystem: : InvalidParameter) ; 

}; // end of ModifyResultlterator 

* The BasicCmlrpOperations interface. 

* Supports a number of Resource Model versions. 
V 

interface BasicCmlrpOperations 
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/** 

* Get the version (s) of the interface 

* @raises GetBasicCmlRPVersion when the system for some reason 

* can not return the supported versions. 

* @returns all supported versions. 
V 

ManagedGenericIRPConstDef s : : Vers ionNumber Set get_basicCm_IRP_version ( ) 
raises (GetBasicCmlRPVersion) ; 

/*■* 

* Return the operation profile for a specific Basic CM IRP version. 

* @raises GetBasicCmlRPOperationProf lie when the system for some reason 

* cannot return the supported operations and parameters. 

* @returns the list of all supported operations and their supported 

* parameters for the specified version. 
V 

ManagedGenericIRPConstDef s : :MethodList get_basicCm_IRP_operation_prof lie 
( 

in ManagedGenericIRPConstDef s : : VersionNumber basicCm_IRP_version 
) 
raises ( 

GetBasicCmlRPOperationProf lie, 

ManagedGeneric IRP System: : OperationNot Supported, 

ManagedGenericIRPSystem: : InvalidParameter ) ; 

* Return the notification profile for a specific Basic CM IRP version. 
* 

* @raises GetBasicCmlRPNotif icationProf lie when the system for some 

* reason cannot return the supported notifications and parameters. 

* @returns the list of all supported notifications and their supported 

* parameters for the specified version. 
V 

ManagedGenericIRPConstDef s : :MethodList 

get_basicCm_IRP_notif ication_prof lie ( 

in ManagedGenericIRPConstDef s : : VersionNumber basicCm_IRP_version 
) 
raises ( 

GetBasicCmlRPNotif icationProf lie, 

ManagedGenericIRPSystem: : OperationNot Supported, 

ManagedGenericIRPSystem: : InvalidParameter) ; 



/ 



** 



* Performs a containment search, using a SearchControl to 

* control the search and the returned results. 
* 

* All MOs in the scope constitute a set that the filter works on. 

* The result BasicCmInf ormationlterator contains all matched MOs, 

* with the amount of detail specified in the SearchControl. 

* For the special case when no managed objects are matched in 

* f ind_managed_ob jects, the BasicCmInf ormationlterator will be returned. 

* Executing the next_basicCmInf ormations in the 

* BasicCmInf ormationlterator will return FALSE for 

* completion. 
* 

* @parm baseObject The start MO in the containment tree. 

* @parm SearchControl the SearchControl to use. 

* @parm requestedAttributes defines which attributes to get. 

* If this parameter is empty (""), all attributes shall 

* be returned. In this version this is the only supported semantics. 

* Note that this argument is only 
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* relevant if ResultContents in the search control is 

* specif ed to NAMES_AND_ATTRIBUTES . 
* 

* @raises ManagedGenericIRPSystem: : ValueNotSupported if a valid but 

* unsupported parameter value is passed. E.g. the contents 

* field in the searchcontrol parameter contains the value NAMES and 

* the optional getContainment IS operation is not supported. 

* Sraises Undef inedMOException The MO does not exist. 

* @raises IllegalDNFormatException The dn syntax string is 

* malformed. 

* Sraises IllegalScopeTypeException The ScopeType in scope contains 

* an illegal value. 

* @raises IllegalScopeLevelException The scope level is negative 

* (<0) . 

* @raises IllegalFilterFormatException The filter string is 

* malformed. 

* @raises FilterComplexityLimit if the filter syntax is correct, 

* but the filter is too complex to be processed by the IRP agent. 

* @see SearchControl 

* @see BasicCmInf ormationlterator 
V 

BasicCmInf ormationlterator f ind_managed_ob jects ( 

in BasicCMIRPConstDefs : :DN baseObject, 

in BasicCMIRPConstDef s :: SearchControl searchControl, 

in BasicCMIRPConstDef s : :AttributeNameSet requestedAttributes ) 
raises ( 

FindManagedOb jects, 

ManagedGenericIRPSystem: : ParameterNot Supported, 

ManagedGenericIRPSystem: : InvalidParameter, 

ManagedGenericIRPSystem: : ValueNotSupported, 

ManagedGenericIRPSystem: : Ope r at ionNot Supported, 

Undef inedMOException, 

IllegalDNFormatException, 

Undef inedScopeExcept ion, 

IllegalScopeTypeException, 

IllegalScopeLevelException, 

IllegalFilterFormatException, 

FilterComplexityLimit) ; 

* Performs the creation of a MO instance in the MIB maintained 

* by the IRP Agent . 
* 

* @parm objectName: the distinguished name of the MO to create. 

* @parm ref erenceOb ject : the distinguished name of a reference MO. 

* @parm attributes: in input, initial attribute values for the MO to 

* create; in output, actual attribute values of the created MO. 

* @parm attributeErrors : errors, related to attributes, that caused the 

* creation of the MO to fail. 
* 

* @raises ManagedGenericIRPSystem: : OperationNotSupported: The operation 

* is not supported. 

* @raises ManagedGenericIRPSystem: : ParameterNotSupported: An optional 

* parameter is not supported. 

* @raises ManagedGenericIRPSystem: : InvalidParameter : An invalid 

* parameter value has been provided. 

* @raises Undef inedMOException : The MO does not exist. 

* @raises IllegalDNFormatException: The DN syntax string is malformed. 

* @raises DuplicateMO: A MO already exist with the same DN as the one 

* to create. 

* @raises CreateNotAllowed: The creation of the MO is not allowed. 

* @raises Ob jectClassMismatch : The object class of the MO to create does 
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* not match with the object class of the provided reference MO. 

* @raises NoSuchOb jectClass : The class of the object to create is not 

* recognized. 

* Sraises ParentOb jectDoesNotExist : The parent MO instance of the 

* ManagedEntity specified to be created does not exist. 
V 

void create_managed_ob ject ( 

in BasicCMIRPConstDefs : :DN objectName, 

in BasicCMIRPConstDef s : :DN ref erenceOb ject , 

inout BasicCMIRPConstDef s : :MOAttributeSet attributes, 

out BasicCMIRPConstDef s : :AttributeErrorSeq attributeErrors 
) 
raises ( 

CreateManagedOb ject, 

ManagedGenericIRP System: : Ope r at ionNot Supported, 

ManagedGenericIRP System: : ParameterNot Supported, 

ManagedGenericIRPSystem: : InvalidParameter, 

Undef inedMOException, 

I llegalDNFormat Except ion, 

DuplicateMO, 

Cre at eNotAl lowed, 

Ob jectClassMismatch, 

NoSuchOb jectClass, 

ParentOb JectDoesNotExist ) ; 

/*■*■ 

* Performs the deletion of one or more MO instances from the MIB 

* maintained by the IRPAgent, using a SearchControl to control the 

* instances to be deleted. 
* 

* All MOs in the scope constitute a set that the filter works on. 

* All matched MOs will be deleted by this operation. 

* The returned DeleteResult Iterator is used to retrieve the DNs of the 

* MOs deleted and the errors that may have occurred preventing deletion 

* of some MOs. 

* For the special case when no managed objects are matched in 

* delete_managed_ob jects, the DeleteResultlterator will be returned. 

* Executing the next_basicCmInf ormations in the DeleteResultlterator 

* will return FALSE for completion. 
* 

* @parm baseObject: the start MO in the containment tree. 

* @parm searchControl : the SearchControl to use; field "contents" has no 

* meaning here and shall be ignored. 
@returns: a DeleteResultlterator (see above). 

* 

* @raises ManagedGenericIRPSystem: : OperationNotSupported: The operation 

* is not supported. 

* @raises ManagedGenericIRPSystem: : InvalidParameter : An invalid 

* parameter value has been provided. 

* @raises Undef inedMOException : The MO does not exist. 

* @raises IllegalDNFormatException : The DN syntax string is malformed. 

* @raises IllegalScopeTypeException : The ScopeType in scope contains 

* an illegal value. 

* @raises IllegalScopeLevelException : The scope level is negative (<0) . 

* Sraises IllegalFilterFormatException : The filter string is malformed. 

* Sraises FilterComplexityLimit : The filter syntax is correct, 

* but the filter is too complex to be processed by the IRPAgent. 
*/ 

DeleteResultlterator delete_managed_ob jects ( 
in BasicCMIRPConstDefs : :DN baseObject, 
in BasicCMIRPConstDef s :: SearchControl searchControl 

) 

raises ( 
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DeleteManagedOb jects, 

ManagedGenericIRPSystem: : OperationNot Supported, 

ManagedGenericIRPSystem: : InvalidParameter, 

Undef inedMOException, 

I llegalDNFormat Except ion, 

Undef inedScopeExcept ion, 

IllegalScopeTypeException, 

II legal ScopeLevelExcept ion, 

II legalFi It erFormat Except ion, 

FilterComplexityLimit ) ; 

* Performs the modification of MO attributes. One or more MOs attributes 

* may be modified according to a SearchControl . 
* 

* All MOs in the scope constitute a set that the filter works on. 

* All matched MOs will have their attributes modified by this operation. 

* The returned ModifyResult Iterator is used to retrieve the DNs of the 

* modified MOs together with the values of the modified attributes, and 

* the errors that may have occurred preventing modification of some 

* attributes. 

* For the special case when no managed objects are matched in 

* modify_managed_ob jects, the ModifyResultlterator will be returned. 

* Executing the next_basicCmInf ormations in the ModifyResultlterator 

* will return FALSE for completion. 

* @parm baseObject: the start MO in the containment tree. 

* @parm searchControl : the SearchControl to use; field "contents" has no 

meaning here and shall be ignored. 

* @parm modifications: the values for the attributes to modify and 

the way those values are to be applied to the attributes. 

@returns: a ModifyResultlterator (see above) . 
* 

* @raises ManagedGenericIRPSystem: : OperationNotSupported: The operation 

* is not supported 

* @raises ManagedGenericIRPSystem: : InvalidParameter : An invalid 

* parameter value has been provided 

* @raises Undef inedMOException : The MO does not exist. 

* @raises IllegalDNFormatException : The DN syntax string is malformed. 

* @raises IllegalScopeTypeException: The ScopeType in scope contains 

* an illegal value. 

* Sraises IllegalScopeLevelException : The scope level is negative (<0) . 

* @raises IllegalFilterFormatException : The filter string is malformed. 

* @raises FilterComplexityLimit: The filter syntax is correct, 

* but the filter is too complex to be processed by the IRP Agent . 
V 

ModifyResultlterator modify_managed_ob jects ( 

in BasicCMIRPConstDefs : :DN baseObject, 

in BasicCMIRPConstDef s :: SearchControl searchControl, 

in BasicCMIRPConstDef s : :AttributeModificationSet modifications 
) 
raises ( 

Modi fyManagedOb jects, 

ManagedGenericIRPSystem: : OperationNotSupported, 

ManagedGenericIRPSystem: : InvalidParameter, 

Undef inedMOException, 

IllegalDNFormatException, 

Undef inedScopeExcept ion, 

IllegalScopeTypeException, 

IllegalScopeLevelException, 

IllegalFilterFormatException, 

FilterComplexityLimit) ; 
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#endif // _BASICCMIRPSYSTEM_IDL_ 
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